home *** CD-ROM | disk | FTP | other *** search
- ;;; -*- Package: SPARC -*-
- ;;;
- ;;; **********************************************************************
- ;;; This code was written as part of the Spice Lisp project at
- ;;; Carnegie-Mellon University, and has been placed in the public domain.
- ;;; If you want to use this code or any part of Spice Lisp, please contact
- ;;; Scott Fahlman (FAHLMAN@CMUC).
- ;;; **********************************************************************
- ;;;
- ;;; $Header: memory.lisp,v 1.1 90/11/30 17:04:52 wlott Exp $
- ;;;
- ;;; This file contains the SPARC definitions of some general purpose memory
- ;;; reference VOPs inherited by basic memory reference operations.
- ;;;
- ;;; Written by Rob MacLachlan
- ;;;
- ;;; Converted by William Lott.
- ;;;
-
- (in-package "SPARC")
-
- ;;; Cell-Ref and Cell-Set are used to define VOPs like CAR, where the offset to
- ;;; be read or written is a property of the VOP used. Cell-Setf is similar to
- ;;; Cell-Set, but delivers the new value as the result. Cell-Setf-Function
- ;;; takes its arguments as if it were a setf function (new value first, as
- ;;; apposed to a setf macro, which takes the new value last).
- ;;;
- (define-vop (cell-ref)
- (:args (object :scs (descriptor-reg)))
- (:results (value :scs (descriptor-reg any-reg)))
- (:variant-vars offset lowtag)
- (:policy :fast-safe)
- (:generator 4
- (loadw value object offset lowtag)))
- ;;;
- (define-vop (cell-set)
- (:args (object :scs (descriptor-reg))
- (value :scs (descriptor-reg any-reg)))
- (:variant-vars offset lowtag)
- (:policy :fast-safe)
- (:generator 4
- (storew value object offset lowtag)))
- ;;;
- (define-vop (cell-setf)
- (:args (object :scs (descriptor-reg))
- (value :scs (descriptor-reg any-reg)
- :target result))
- (:results (result :scs (descriptor-reg any-reg)))
- (:variant-vars offset lowtag)
- (:policy :fast-safe)
- (:generator 4
- (storew value object offset lowtag)
- (move result value)))
- ;;;
- (define-vop (cell-setf-function)
- (:args (value :scs (descriptor-reg any-reg)
- :target result)
- (object :scs (descriptor-reg)))
- (:results (result :scs (descriptor-reg any-reg)))
- (:variant-vars offset lowtag)
- (:policy :fast-safe)
- (:generator 4
- (storew value object offset lowtag)
- (move result value)))
-
- ;;; Define-Cell-Accessors -- Interface
- ;;;
- ;;; Define accessor VOPs for some cells in an object. If the operation name
- ;;; is NIL, then that operation isn't defined. If the translate function is
- ;;; null, then we don't define a translation.
- ;;;
- (defmacro define-cell-accessors (offset lowtag
- ref-op ref-trans set-op set-trans)
- `(progn
- ,@(when ref-op
- `((define-vop (,ref-op cell-ref)
- (:variant ,offset ,lowtag)
- ,@(when ref-trans
- `((:translate ,ref-trans))))))
- ,@(when set-op
- `((define-vop (,set-op cell-setf)
- (:variant ,offset ,lowtag)
- ,@(when set-trans
- `((:translate ,set-trans))))))))
-
-
- ;;; Slot-Ref and Slot-Set are used to define VOPs like Closure-Ref, where the
- ;;; offset is constant at compile time, but varies for different uses. We add
- ;;; in the stardard g-vector overhead.
- ;;;
- (define-vop (slot-ref)
- (:args (object :scs (descriptor-reg)))
- (:results (value :scs (descriptor-reg any-reg)))
- (:variant-vars base lowtag)
- (:info offset)
- (:generator 4
- (loadw value object (+ base offset) lowtag)))
- ;;;
- (define-vop (slot-set)
- (:args (object :scs (descriptor-reg))
- (value :scs (descriptor-reg any-reg)))
- (:variant-vars base lowtag)
- (:info offset)
- (:generator 4
- (storew value object (+ base offset) lowtag)))
-
-
-
- ;;;; Indexed references:
-
- ;;; Define-Indexer -- Internal
- ;;;
- ;;; Define some VOPs for indexed memory reference.
- ;;;
- (defmacro define-indexer (name write-p op shift)
- `(define-vop (,name)
- (:args (object :scs (descriptor-reg))
- (index :scs (any-reg zero immediate))
- ,@(when write-p
- '((value :scs (any-reg descriptor-reg) :target result))))
- (:arg-types * tagged-num ,@(when write-p '(*)))
- (:temporary (:scs (non-descriptor-reg)) temp)
- (:results (,(if write-p 'result 'value)
- :scs (any-reg descriptor-reg)))
- (:result-types *)
- (:variant-vars offset lowtag)
- (:policy :fast-safe)
- (:generator 5
- (sc-case index
- ((immediate zero)
- (let ((offset (- (+ (if (sc-is index zero)
- 0
- (ash (tn-value index)
- (- vm:word-shift ,shift)))
- (ash offset vm:word-shift))
- lowtag)))
- (etypecase offset
- ((signed-byte 13)
- (inst ,op value object offset))
- ((or (unsigned-byte 32) (signed-byte 32))
- (inst li temp offset)
- (inst ,op value object temp)))))
- (t
- ,@(unless (zerop shift)
- `((inst srl temp index ,shift)))
- (inst add temp ,(if (zerop shift) 'index 'temp)
- (- (ash offset vm:word-shift) lowtag))
- (inst ,op value object temp)))
- ,@(when write-p
- '((move result value))))))
-
- (define-indexer word-index-ref nil ld 0)
- (define-indexer word-index-set t st 0)
- (define-indexer halfword-index-ref nil lduh 1)
- (define-indexer signed-halfword-index-ref nil ldsh 1)
- (define-indexer halfword-index-set t sth 1)
- (define-indexer byte-index-ref nil ldub 2)
- (define-indexer signed-byte-index-ref nil ldsb 2)
- (define-indexer byte-index-set t stb 2)
-
-